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(57) Abstract 

A method for generating a compact dilifferenco result bet^ an 
old program and a new progiam. Each P^sram j^nduding r^cx^^ 
entrirdiat contain reference that refer to otith« cnOies ^ *e pwpam. 
TTie method includes the steps of scannmgg the old ^^^^^ 
each reference entry perfomi stepstfiat taclUnde ^^^^^^."^^ 
of the entry by a distinct label mark, wherebby a modified old program 
S. SnS. There is ftnther provided dies step of scanntag the new 
pnfgram and for each referenceentty P«f<f??»^*»«'^S?:^SS 
Se reference of the entry by a distinct labd n«r^ "^IT^f 
new program is generated. There is stffl fiiurther provided tte step of 
SereffSe specified different result utimizing directly or indirectly 
the modified old program and modified new ? program. 
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DIFFERENCE EXTRACTION BETWEEN TWO VERSIONS 
OF DATA-TABLES CONTAINING INTRA-REFERENCES 



FIELD OF THE INVENTION 

This mvention relates generaUy to updating computer progran^ 

BACKGROUND OF THE INVENTION 
5 With the ever increasing use of remote communication and in particular tiie 

Internet, new applications have been introduced such as conunercial trade over the 
Internet; electronic supennaikets, distiibution of computa* products over tiie 
Internet, and others. 

Both &e popularity and availability of access to the Internet for common 
10 users have encouraged not only the distribution of products, but also the upgrade 
and update of the product under question from a remote site, using, to this end, the 
Internet infia-structure. 

Turning to a specific example of computer programs, an old pro-am is 
installed at^ remote client site and is subject to be upgraded to a new program, 
15 where the latter includes some modifications as compared to the old program. 

In order to cany out the xq^date at the remote client site (through the 
network), the provider should, preferably, generate a difference result 
. representative of the difference between the old program and the new program, and 
send the resulting file through the Internet to the remote climt site. The client, in 
20 turn, invokes appropriate utility, which mcorporates the differences in the old 
' program, thereby generating the desired new program at the client site. The 
specified procedure carries the obvious advantages in that on the one hand, the 
provider does not need to be present at the client site and, on the other hand, only 
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tfae diflference result and not the entire new program is sent to the client Assuming, 
for example, that a modified Office '97 package (commercially available from 
Microsoft Inc. USA) should be sent to cUents, since the compressed size of 
programs of the package occupies tens of Mega-bytes, and, further considering the 
5 relatively low throughput of tiie Internet and the bottleneck of the modem 
throughput at the client end (say an average of 33,600 bps), it is easy to undei:stand 
that transmitting the entire new package through the network is practically 
infeasible. 

Normally, the volume of the difference result is significantly smaller than 

10 that of tiie raw new program and, accordingly, sending only the difference result 
data rather than the entire new program, is more efficient This notwithstan d i ng , 
and as will be explained in grcato: detail below, flying known per se file 
difference applications (such as techniques utilized by utilities of the UNIX 
operating systems or a similar ^fi^utility of fte GNU project from FSF) in order to 

IS generate a difference result between the old program and tiie new progranti, 
normally results in a relatively large amount of data, even if the modifications that 
were introduced to the old program (in order to generate the new program) are 
very few. Thus, consider, for example, an old program where few new instructions 
are inserted and few others are deleted m order to bring about the new program. 

20 The difference result between the old program and the new program will not only 
reveal the inserted and deleted instructions, but also all those entries that jump, 
jump on condition, call functions, reference to data and possibly o&icxs (referred to, 
collectively, as reference entries - see glossary below) which, by nature, specify a 
target address (reference) as an integral part of the cominand. The latter addresses 

25 may have been changed due to tiie &ct that some mstructions were added and 
others deleted It is important to note that the reference entries that are modified 
are not those that were inserted, and obviously not those that were deleted. In feet, 
insertion of only one new entry may result in the plurality of altered reference 
entries which will naturally be reflected in the difference result and obviously will 

30 inflate its volxime. 
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It is accordingly ^preciated that despite the fact that the actual change 
between the old and new program is very limited, the resulting file difiference is 
relatively large. The same problem is encountered in other applications^ which 
employ data tables (see Glossary below), that are structured like a program and are 

5 subject to i;)dates in tiiemamier specified. 

There is accordingly a need in the ait to provide for an efBcient tool which 
will result in significanfly smaller volumes of difference results between old 
programs and new programs, as compared to hitherto known techniques for 
accomplishing difference result The proposed tool is useful for various 

10 applications including, but not limited to, incremental software updates and v^ion 
control. 

There is yet another need in the art to provide for an efficient tool which will 
result in significantly smaller volumes of difference results between old data tables 
and new data tables. 

GLOSSARY: 

There follows a glossary of terms, some of which are conventional and 
others have been coined: 

20 

Data Table - a table of entries^ each may have a different size; 

Entry - a data table includes entries^ each of which is an addressable unit 
that contains data; 

25 

Address - a number which is uniquely assigned to a smgle entry by which 
that entry is accessed; In the following description, the terms entry and address are 
occasionally used interchangeably. 
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Reference- a part of the data appearing in an ent?y in the data table which 
is used to refer to some other entry &Qm the same data table. A reference can be 
either an address or a number used to compute an address. Entries that inchide 
references are designated also as reference entries. 

5 

Label - an abstract notation of an entry which is referred fay another entry of 
the same data table through a reference. 

Old Data Table - a data table (or portion of a data table) that is to be updated 
10 (possibly from remote site) so as to generate a new data table (or portion of a new 
data table). Insofar as remote update is concemed, it is normally, altiiough not 
necessarily, transmitted through a commimication network such as the Internet It 
should be noted &at vAiilst for convenience of explanation only, the description 
focuses predominately on the Internet, the invention is by no means bound by this 
15 specific example. 

As an example, a data table can be an executable program either as a loaded 
program in machine-memory or as an executable-file. In this example, entries are 
individual machine instructions of the program or the individual data elements used 
20 by the program. 

Instructions and data elements of a program may contain addresses to other 
instructions or data elements and are regarded as references. Such references can be 
detected by a process of disassembly applied on the program or, if given, by 
analyzmg a relocation table attached to executable programs by link-editors that 
25 create them. 

Another example of a data table is a group of inter-linked data records 
stored ra an array of bytes where records contain addresses of other data records. 
The format of the records and the way they are laid out in the array are known, and 
the analysis and decomposition of such array is possible. 

30 
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Old program - an example of old data table: a program (or portion of a 
program) that is to be updated so as to generate a new program (or portion of a 
program). 

It should be further noted that reference to the old program and the new 
5 program is made for convenience of eqilanadon only, and encompasses inter alia 
the ijpgrade of the old program to the new program (e.g. due to an upgrade in 
versions), modifications of the old program to the new program, (e.g. due to 
corrections of bugs in the old program), and changing from a first old program to a 
second (and possibly different) new program; 

10 

SUMMARY OF THE mVEimON 

For convenience of explanation, the invention is described with reference to 
a specific example of computer programs. The invention is by no means bound by 
this particular exan^le. 

15 As eiqjlained above, applying a known per se file difference utility to an old 

program and a new program nomially results m a relatively large amount of data, 
even if the modifications that were introduced to the old program (in order to 
generate the new program) are very few. The present mvention is based on the 
observation that the relatively large size of the difference result stems from the 

20 alterations of reference in reference entries as a result of otiier newly inserted 
entries (and/or entries that were deleted). 

On the basis of this observation, the invention aims at generating a modified 
old program and a modified new program, wherein the difference in references in 
corresponding entries in said new and old programs as explained above, will be 

25 reflected as invariant entries in the modified old and new programs. The net effect 
is that the invariant reference entries (between the modified old program and the 
modified new program), will not appear in the difference result, thereby reducing 
its size as compared to a conventicmal difference result obtained by using hitherto 
known techniques- 
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Accordingly, the invention provides for a method for generating a 
compact difference result between an old program and a new program; each 
program inclnding reference entries that contain reference that refer to other 
entries in the program; the method comprising the steps of: 
5 (a) scanning the old program and for substantially each 
reference entry perform steps that include: 
(i) replacing the reference of said entry by a 
distinct label mark, whereby a modified old 
program is generated; 
]0 (b) scanning the new program and for substantially each 
reference entry perform steps that include: 
(i) replacing the reference of said entry by a 
distinct label mark, whereby a modified new 
program is generated; 
^5 (c) generating said diflference result ufiUzmg directly or 
indirectly at least said modified old program and modified 
new program. 

■ The invention further provides for a method for performing an update in an 
20 old program so as to generate a new program; each program including reference 
entries that contain reference that refer to other entries in the program; the 
method comprising the steps of: 

(a) receiving data that includes a compact difference result; 
25 said compact difference result was generated utilizing a 

modified old program and a modified new program; 

(b) scanning the old program and for substantially each 
reference entry perform steps that include: 

(i) replacing the reference of said entry by a 
3Q distinct label mark, whereby the modified old 
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program is generated; 

(c) reconstituting tiie modified new program utilizing at least 
said compact difference result and said modified old 
program; said modified new program is differed fi^om said 

5 new program at least in that substantially each reference 

entry in said new program is replaced in said modified new 
program by a distinct label mark; 

(d) reconstituting said new program utili2dng directiy or 
indirectiy at least said compact difference result and said 
modified new program. 

Still fixrtiier, the invention provides for a method for generating a compact 
difference result between an old program and a new program; each program 
including reference entries that contain reference that refer to other entries in the 
15 program; tiiemettiod comprising flie steps of: 

(a) generating a modified old program utilizing at least said 
old program; 

(b) generating a modified new program utilizing at least said 
new program, said modified old program and modified new 

2Q program have at least the following characteristics: 

(i) substantially each reference in an entry in said 
old program that is different than corresponding 
entry in said new program due to delete/insert 
modifications that form part of the transition 

25 between said old program and new program are 

reflected as invariant references in the 
corresponding enteies in said modified old and 
modified new programs; 

(c) generating said compact, difference result utilizing at least 
30 said modified new program and modified old program. 
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Yet further, the invention provideis for a method for perfonning an update in 
an old program so as to generate a new program; each program including 
5 reference entries that contain reference that refer to other entries in the program; 
the method comprising the steps of: 

(a) receiving data that includes a compact difference result; 
said compact difference result was generated utilizing a 
modified old program and a modified new program; 

(b) generatmg a modified old program utilizing at least said old 
program; 

(c) reconstituting a modified new program utilizing directly or 
indirectly at least said modified old program and said 
compact difference result; said modified old program and 
modified new program have at least the foUowmg 
characteristics: 

(i) substantially each reference in an entry in said 
old program that is different than corresponding 
entry in said new program due to delete/inset 
modifications that form part of the transition 
between said old program and new program are 
reflected as invariant references in the 
corresponding entries m said modified old and 
25 modified new programs; 

, (d) reconstituting said new program utilizmg directiy or 
indirectiy at least said compact difference result and said 
modified new program. 



15 
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According to another aspect, the invention provides for a system for 
generating a compact difference result between an old program and a new 
program; each program including reference entries that contain reference that 
refer to other entries in tiie program; the system comprising a processing device 
5 capable of: 

(a) scanning the old program and for substantially each 
reference entry perform steps that include: 

(i) replacing the reference of said entiy by a 
distinct label mark, whereby a modified old 
10 program is generated; 

(b) scanning the new program and for substantially each 
reference entry perform steps that include: 

(i) replacing the reference of said entry by a 
distinct label mark, whereby a modified new 
15 program is generated; 

(c) generating said difference result utili2dng directly or indirectly at 
least said modified old program and modified new program. 

Still further, the invention provides for a system for performing an update in 
20 an old program so as to generate a new program; each program including 
reference entries that contain reference that refer to other entries in the program; 
the system comprising a processing device capable of : 

(a) receiving data that includes a compact difference result; 
25 said compact difference result was generated utili2mg a 

modified old program and a modified new program; 

(b) scanning the old program and for substantially , each 
reference entry perform steps that mclude: 

(i) replacing the reference of said entry by a 
30 distinct label mark, whereby the modified old 



It! 
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program is generated; 

(c) reconstituting the modified new program utilizing at least 

said compact difference result and said modified old 
program; said modified new program is diff^ed from said 
5 new program at least in that substantially each reference 

entry in said new program is replaced in said modified new 
program by a distinct label mark; 

(d) reconstituting said new program utilizing directly or 
indirectly at least said compact difference result and said 

20 modified new program. 

The invention fiirflxer provides for a system for generating a compact 
difference, result between an old program and a new program; each program 
including reference entries that contain reference that refer to other ratries in the 
15 program; the system comprising a processing device capable of: 

(a) generating a modified old program utilizing at least said 
old program; 

(b) generating a modified new program utilizing at least said 
new program, said modified old program and modified new 

20 program have at least the following characteristics: 

(i) substantially each reference in an entry in said 
old program that is different than corresponding 
wtxy in said new program due to delete/insert 
modifications, that form part of the transition 

25 between said old program and new program are 

reflected as invariant references in the 
corresponding entries in said modified old and 
modified new programs; 

(c) generating said compact difference result utilizing at least 
30 said modified new program and modified old program. 
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Still further, the invention provides for a system for performing an update in 
an old program so as to generate a new program; each program including 
reference entries that contain reference that refer to other entries in the program; 
5 the system comprising a processing device capable of : 

(a) receiving data that includes a compact difference result; 
said compact difference result was generated utilizing a 
modified old program and a modified new program; 
\Q (b) generating a modified old program utilizing at least said old 
program; 

(c) reconstituting a modified new program utilizing directly or 
indirectly at least said modified old program and said 
compact difference result said modified old program and 
j5 modified new program have at least the following 

characteristics: 

(Q substantially each reference in an entry in said 
old program that is different than corresponding 
entry in said new program due to delete/inset 
20 modifications that form part of the transition 

between said old program and new program are 
reflected as invariant references in the 
corresponding entries in said modified old and 
modified new programs; 
25 (d) reconstituting said new program utilizmg directly or 

indirectly at least said compact difference result and said 

modified new program. 



Yet further, the invention provides for a method for generating a compact 
30 difference result between an old data table and a new data table; each data table 
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including reference entries that contain reference that refer to other entries in the 
data table; the method comprising the steps of: 

(a) scanmng the old data table and for substantially each 
reference entiy perform steps that include: 

(i) replacing the reference of said entzy by a 
distinct label mark, whereby a modified old data 
table is generated; 

(b) scanning the new data table and for substantially each 
reference entry perform steps that include: 

(i) replacing the reference of said entry by a 
distinct label mark, whereby a modified new data 
table is generated; 

(c) generating said difference result udlizing directly or 
indirectly at least said modified old data table and modified 
new data table. 

Moreover, the inventicm provides for a method for performiiig an update in 
an old data table so as to generate a new data table; each data table including 
reference entries that contain reference that refer to other, entries in the data table; 
the method comprising the steps of: 

(a) receiving data that includes a compact difference result; 
said compact difference result was generated utilizing a 
modified old data table and a modified new data table; 

(b) scanning the old data table and for substantially each 
reference entry perform steps that include! 

(i) replacing the reference of said entry by a 
distinct label mark, whereby the modified old 
data table is generated; 

(c) reconstituting the modified new data table utilizing at least 
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said compact difference result and said modified old data 
table; said modified new data table is differed from said 
new data table at least in that substantially each reference 
entry in said new data table is r^laced in said modified 
new data table by a distinct label mark; 
(d) reconstituting said new data table utilizing directly or 
indirectly at least said compact difference result and said 
modified new data table. 

The invention further provides for a method for generating a compact . 
difference result between an old data table and a new data table; each data table 
including reference entries tiiat contain reference that refer to other entries in the 
data table; the method comprising the steps o£ 

(a) generating a modified old data table utilizing at least said 
old data table; 

(b) generating a modified new data table utilizing at least said 
new data table, said modified old data table and modified 
new data table have at least the following characteristics: 
(i) substantially each reference in an entry in said , 

old data table that is different than corresponding 
entry in said new data table due to delete^nsert 
modifications that fonn part of the transition . 
between said old data table and new data table are 
reflected as invariant references in the 
corresponding entries in said modified old and 
modified new data tables; 
' (c) generating said compact difference result utilizing at least 
said modified new data table and modified old data table. 
The invention provides for a method for performing an update*in an old data 
table so as to generate a new data table; each data table including reference 
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entries that contain reference that refer to other entries in the data table; the 
method comprising the steps of: 

(a) receiving data that includes a compact difference result; 

5 said compact difference result was generated utilizmg a 

modified old data table and a modified new data table; 

(b) generating a modified old data table utilizing at least said 
old data table; 

(c) reconstituting a modified new data table utilizing directly 
or indirectly at least said modified old data table and said 
compact difference result; said modified old data table and 
modified new data table have at least the following 
characteristics: 

(i) substantially eadi reference in an entry in said 
13 old data table that is different than corresponding 

entry in said new data table due to delete^et 
modifications that fomi part of the transition 
between said old data table and new data table are 
reflected as invariant references in the 
2Q corresponding entries in said modified old and 

modified new data tables; 

(d) reconstituting said new data table utilizing directly or 
indirectly at least, said compact difference result and said 
modified new data table. 

25 The invention further, provides for a system for generating a compact 
difference result between an old djata table and a new data table; each data table 
including reference entries that contain reference that refer to other entries in the 
data table; the system comprising a processing device capable of: 

(a) scanning the old data table and for substantially each 

30 reference entry perform steps that include: 
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(i) replacing the reference of said entry by a 
distinct label mark, whereby a modified old data . 
table is generated; 

(b) scaxming the new data table and for substantially each 
reference mtcy perfonn steps tiiat inchide: 

(i) replacing the reference of said entry by a 
distinct label mark, whereby a modified new data 
table is generated; 

(c) generating said difference result utilizing directly or indirectly at 
least said modified old data table and modified new data table. 

Still fiirther, the invention provides for a system for performing an update in. 
an old data table so as to generate a new data table; each data table including 
reference entries Aat contain reference that refer to other entries in ttie data table; 
the system comprising a processing device capable of : 

(a) receiving data that includes a compact difference result; 
said compact difference result was generated utilizing a 
modified old data table and a modified new data table; 

(b) scanning the old data table and for substantially each 
reference entry perform steps that include: 

(1) replacing the reference of sjud entry by a 
distinct label mark, whereby the modified old 
data table is generated; 

(c) reconstituting the modified new data table utilizing at least 
said compact difference result and said modified old data . 
table; said modified new data table is differed from said 
new data table at least in that substantially each reference 
entry in said new data table is replaced in said modified 
new data table by a distinct label mark; 

(d) reconstituting said new data table utilizing directly or 
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indirectly at least said compact difference result and said 

modified new data table. 
Moreover, the invention provides, for a system for generating a compact 
difference result between an old data table and a new data table; each data table 
including reference entries that contain reference &at refer to other mtries in the 
data table; the system comprising a processing device capable of : 

(a) generating a modified old data table utilizing at least said 
old data table; 

(b) generating a modified new. data table utilizing at least said 
new data table, said modified old data table and modified 
new data table have at least the following characteristics: 
Q) . substantially each reference m an entiy in said 

old data table that is different than corresponding 
entiy in said new data table due to delete/insert 
modificadqns Aat fonn part of the transition 
between said old data table and new data table are 
reflected as invariant references in the 
coiresponding entries in said modified old and 
modified new data tables; 

(c) generating said compact difference result utilizing at least 
said modified new data table and modified old data table. 

The invention provides for a system for performing an update in an old data 
table so as to generate a new data table; each data table including reference 
entries that contain reference that refer to other entries in the data table; the 
system comprising a processing device capable of : 

(a) receiving data that includes a compact difTerence result; 
said compact difference result was generated utilizing a 
modified old data table and a modified new data table; 
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(b) generating a modified old data table utilizing al least said 
old data table; 

(c) reconstituting a modified new data table utilizing directly 
or indirectly at least said modified old data table and said 
compact difference result; said modified old data table and 
modified new data table have at least the following 
characteristics: 

© substantially each reference in an entry in said 
old data table that is different than corresponding 
entry in said new data table due to delete^et 
modificafions that form part of the transition 
between said old data table and new data table are 
reflected as invariant references in the 
corresponding entries in said modified old and 
modified new data tables; 
(d) reconstituting said new data table iitiliang directly or 

indirectly at least said compact difference result and said 

modified new data table. 

BRIEF DESCRIPTION OF THE DRAWINGS 

In order to understand the invention and to see how it may be carried out in 
practice, a preferred embodiment will now be described, by way of non-limiting 
example only, with reference to the accompanying drawings, in which: 

Fig. 1 is a schematic illustration of a sequence of operation according to 
onejembodiment of the invention; 

Fig. 2 shows exemplary old and new programs and the various mterim 
results that are obtained by applying the sequence of operation of Fig 1 ; and 

Fig. 3 is an exemplary data table, presented in the form of graph which is 
subject to difference extraction in accordance with the invention. 
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DETAILED DESCRIFnON OF A PREFERRED EMBODIMENT 



In Fig. 1, module (10) represmts the sequence of operations per&nned eg. 
at ±e provider site, for gmerating the difference result according to one 
5 embodiment of the invention. The sequence of operation will now be described 
with reference to exemplary old and new programs (Fig. 2). It should be noted that 
. the specified sequence of operations may be carried out at any known per se 
platfomi including, but not limited to, a conventional P.C., a computer networic, 
etc., all as kaawaperse. • 
10 Thus, Pi stands fijr the old program that includes entries (41), 

(42), (43), (44), (45) and (A6) that contain refcxences to entries 5,8,1,1,13, and 11 
respectively, (as indicated by arrows (41*) to (46*). 

P2 stands for the new program which was generated (or could have bem 
generated) by the sequence of mo<fifications as depicted in the imaginary memory 
15 table (80). Said sequence of modifications (rather real or imaginary), constitutes a 

transition sequence between Pi and Pj. 

As shown in entry no. 6, the reference to address 7' was replaced {'R' 

stands for replaced) by reference to address '11 ' , e.g. due to a patch introduced by 

the programmer; Following the 6* entry, 3 new entries were inserted {T stands for 
20 inserted). The newly inserted entries reside at addresses 7 to 9. The next three 

entries which originally resided in addresses 7 and 9 at P; arc now shifted (due to 

the 3 inserted entries) to addresses 10 to 12 in ft. 

Next, entries 10 and 11 in Pj were deleted (D), and are therefore not 

assigned wifii any address ztPz Entries 12 and 13 in ft remain faitact and reside in 
25 addresses 13 and 14 in Pz Entry 14 in Pj was deleted P) and it is marked as such 

(with no address) in the memory table (80). Lastly, entry (15) remains intact and 

therefore resides in entry 15 in ft. 
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Having reviewed flie seqiioice of modifications that constitute flie transition 
from Pi to P2, Hiere follows a brief review on how the specified modifications 
affected the reference entries of P/ and Pz 

Thus, and as expected, the reference 5 in entry 2 remains intact and it will 
J therefore not appear in Has difference result between Pi and Pi 

The reference 8 m entry 4 of?/ is now modified by reference 11 in entry 4 
of Pz The modification in dereference (fixrai 8 to 11) in entry 4 is caused by the 
insertion of entries 7 to 9 in Pz which obviously shifted entry 8 (m P;)to entry 11 
(m Pi). Before proceeding any finther, it should be noted that applying 
0 conventional file difference appUcation to P; and P: will obviously reflect that 
entry 4 has been changed since the reference 8 has been changed to 11. Those 
versed m the art will readity jqjpredate tiiat according to the invention, it is desired 
to neutralize this change, Mice it has occurred solely due to the feet that 0^12 
entries have been affected Q.e. entries 7 to 9). It is accordingly an object of the 
i5 ravention to give rise to a situation where modifications of this kind will be 
modified to invariant references with the obvious consequence that they are not 
reflected in the diffaence result, thereby keqpmg the latter relatively compact 

Reverting now to the exarnple of Fig. 2, the next reference 1 resides in entry 
6 of Pi. As recalled, this entry was intentionally modified to 11, and as expeOed in 
10 entry 6 of Pz contains reference 11. Unlike the previous reference modification 
which stems firom shifts in the.program and which therefore should be neutralized 
from aiqjearing in the difference results, tiie current modification is applied to the 
entry under question (i.e. the reference in entry 6 has been changed from 1 to 11) 
and should be reflected m the dijGference result Turning now to entry 7 of Pz it 
25 fonns part of the mserted entries, and therefi)re reference 9 thereof is obviously not 
reflected m Pi. Of course, since entry 7 has been inserted, it is expsctsd to appear 
in the difference results^ 

Entry 10, with its associated reference 13, has been deleted from Pi. and as 
expected, it does not appear m P2 and should, of course, be indicated in flie 
30 difference results as an entry for deletion. 
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Entiy 9 wth its associated reference 1 in Pj, corresponds to entry 12 in JP2, 
Since tiie reference in entry 12 remains 1, it will not appear in the difference result 

Turning to die last reference entry 14 in it does not appear in P2 (since it 
was deleted), and therefore it is «pected to appear in ihs difference result as an 
entry for deletiorL 

Having described in general the differences between Pj and Pi as well as 
their eflFect on tfie diflFerence result, attention is now directed also to Fig. 1 for 
describing one non-limiting realization of a system and method of the invention for 
accomplishing the desired difference result 

By this particular embodiment, the desired invariant references are 
accomplished by generating modified old and new programs wherein address 
references in entries are replaced by label marks as follows: 

a) Create P''i table firom Pj (steps POI) and (202) in Fig. 1) and 
P"2 table from P2 (steps (203) and (20^ in Fig. 1) by adding label 
marks and replacing references in entries with some fixed values. As 
shown in Fig. 2, P"i is generated from Pj by adding label marks to 
entries 1, 5, 8, 11 and 13 (designated (101) to (105), respectively). As 
also shown in Fig. 2, the references at entries 2, 4, 6, 9 10 and 14 were 
set to a fixed value and by this particular example 0. Although not 
shown in Fig 2, P"2 is generated in a similar manner; 

b) Create a translation table £1 (step (205) in Fig. 1) between entry 
references in P\ and label distinct values. Thus, and as shown in Fig. 1 
(110), a distinct label number is assigned to each label mark of By 
this particular example, the <tistinct labels are assigned in ascending 
order and, as shown, labels marks (101) to (105) are assigned with the 
respective values 1 to 5; 

c) and P^'i are compared giving rise to difference table D\ (206) 
using file difference utilities of the kind specified above. As shown in 
Fig. 2, 'D\ (120) contains list of entries each having the structure of 
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<X, n>, where X stands for C (copy), I (insert), D(delete), or T 
(Toggle) and n stands for the number of instructions. D\ includes, in 
fact, a list of instructions for generating P"2 from P"i- By this 
particular example, JDi mcludes the followmg entries: <C,6> which 
signifies that the first 6 entries of should be copied to P"2- Note 
that whilst the 6* entry is diflEerent in P\ and P2 (i-e- the reference has 
been changed firom 1 to 11), this entry is the same in P"i and 
,since both references were set to 0 and, accordingly, the 6* entry 
forms part of tiie copied part The next entry <I,3> ,signifies that three 
new entries should be inserted, and this accounts for the new three 
entries 7 to 9 that were inserted to P2 (and are also reflected in 
P"2). The next entry <C,3> stands for the three entries that reside in 
addresses 7 to 9 in P"] (and Pi), and are shifted (without affectiag 
their contents), to addresses 10 to 12 in P"2 (and P2). The next entry 
<D, 2> stands for the two entries (10 and 1 1) that were deleted from Pi 
(and obviously also from P"i). The next entry <C,1> stands for the 
entry 12 in P"i that was shifted (without affecting its contents) to 
entry 13 in P"2' The next entry <T,1> is a special entry indicating that 
a change has occurred in the label of entry 13 of P"i, i.e,. it was 
removed in the corresponding entry 14 in P"2 for the simple reason 
that the entry that refers to this label was deleted (entry 10 in P"i (and 
Pi), <T,1> signifies, thus, that the entry 13 should be copied (to entry 
14), whilst deletmg the label marlc Next, <D,1> stands for the deleted 
entry (14) in P"i, and <C,1> stands for copying tiie last intact entry 
that is to be copied from P"i to P"2 (entry 1 5). 
; d) Analyzing D\ to determine the Position and size of deleted or inserted 
program fragments and apply equivalent changes to L\ translation 
table to create L2 translation table (207), which translates entry 
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references in P2 to their distinct label value in the following manner. 
For a non-inserted referred entry perform: 

• l2[entry address] = ii[matching entry address in Pi] 

(hereinafter the first condition) 
5 For an inserted referred entry, perform: 

• iiCentry address] = U( ) different than any value in ii; 

U( ) signifies a label generatibn function for generating 
distinct labels (hereinafter the second condition). The fbnction 
is of repeatable nature, namely, when activated in the same 
10 scenario it will always generate tiie same result. The latter 

characteristics will be clariJSed when the subsequent program 
reconstruction phase is described below. 
The resulting Li table (130) is shown m Fig.2. Thus, the first six 
instructions fall in the first condition (i.e. non inserted entry) and, 
15 accordingly, the distinct labels (1 and 2) are simply copied from Li. 

The next three entries are inserted and, accordingly, the second 
condition applies and U( ) is activated to generate a distinct label value. 
Since, as shown in Lu five labels are "occupied", Ihe next free one is 6 
and, accordmgly, the reference entry 9 is assigned witii the value 6. 
20 Those versed in the art will readily appreciate that whilst in this 

example U( ) gerierates tiie (fistinct label values by simply incrementing 
the last occupied value by 1, this is only an example. 

Turning now to the next three entries, <C,3> , the reference entry 
1 1 falls in the first criterion and, accordingly, the label value (3) is taken 
25 from Lj, 

The next. entry in Di <D,2> is ignored, since it concerns two 
deleted entries. 

The next entry, <C,1>, has no reference entry and therefore need 
not be processed for generating L2. 
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The next entry, <T,1> ,corresponds to the deleted label (from entry 
13 in L\) and in this respect, is resembles the previous delete 
modification that is ignored. 

The last two entries, <D,1> and <C,1>, do not involve reference 
entries and therefore need not be processed foe the purpose of 
generafmg Li. 

e) Create P'\ (208) and Fi (209) for P\ and P2 respectively, by replacing 
entry references with their translated values using ii and Lz tables and 
by coping label marks from F'l and 

Step (e) will be described with reference to P*\ and applies mutatis 
mutandis also to F'2 (see 150 in Fig. 2). Thus, the label marks (101) 
to (105) of P"i arc copied to the respective locations in P\ (140 in Fig. 
2). Next, the reference entries of Pi are replaced by their 
corresponding label marks as retrieved from Lu More specifically, the 
reference 5 in entry 2 of Pi is replaced by the corresponding label from 
L\. As shown, label 2 resides in entry 5 of L\ and, accordingly, the 
reference ui entry 2 mP*i is set to 2. 

In a sunilar manner, the reference 8 in entry 4 of Pi is replaced by label 
number 3 according to the label number (3) that resides in entry 8 of ii. 
In a similar manner, the references 1,1,13 and 1 1 of entries 6,9,10 and 
14 of Pi are replaced by respective label nimibers 1,1,5 and 4. 

f) Having generated P'l and P'2, the final difference result Di is 
generated. To this end, Di is analyzed to determine the position of 
program fragments copied from Pi to P2 (i.e. in the example of Fig. 2, 
the entries that fall in <C, x> or <T,x> commands; the 
<I, x> <D,x> commands are ignorcd>). For copied entries as derived 
from Di, P'l and P'2 are compared so as to generate Di (210) in the . 
following manner: 
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fl) take each pair of matching entries in P'\ and P'l (neither deleted 
nor inserted) that contain a (replaced) reference, and compare their 
replaced reference values. In the case of discrepancy, add a special 
modification command to reflect the difference. 
f2) attach all the inserted program fragments and replaced values. 
These fragments are taken from P\ thus they contain label marks, and 
address references remain und^ translation. 
Step (f) will now be exemplified with reference to the specific 
example of Fig. 2. As recalled, only entries that fell in a <C^ 
command are of interest for the fl step analysis. Thus, the first 
non-inserted entry of Du i.e. <C,6> is analyzed According to step fl, 
only the six* entry contains a rq>laced reference (reference 1 in as 
compared to reference 3 in P'z). Accordingly, The first command of i>i 
<C,6> is replaced in by <G,5> and a correction command <R,1> 
standing for **replace label in entry 6" is added to Di- Entries 2 and 4 
in P'l (that also fall in the first six entries and are encompassed by the 
<C,6> command), contain the respective references 2 and 3, exactly as 
the corresponding entries in P'2 and, accordingly, no correction 
command is required. 

The rest of tiie entries that correspond to <C,3> <C,1> commands do 
not include replaced references in P'l and P'l and, accordingly, no 
replacement conmiand is required. 

Step f2 simply stipulates that the inserted data and replaced data 
(replaced reference) will be appended to Di in order for the 
reconstructing party to be able to reconstitute. P2 from D2 and Pi . . 
Thus the three entries (that should be inserted to entries 7 to 9 ia P2) 
and which correspond to <I,3> in Z)2, are added to Di in section (161). 
Likewise, the replaced reference 3 (instead of 1) m the six*^ entry 
which corresponds to <R,1> inD^ is added to A ,hi section (161), 



CA. 02339923 2001-02-02 



111 



WO 00/11549 PCT/IL99/00446 

-25-- 

Depending upon the particular application^ Di may be stored on a 
storage medium, or transmitted through a communication network (212 
in Fig. 2), all as required and appropriate. 

There follows a description for a typical sequence of operations 

5 (220) for reconstructing Pi from Pi and the so received Di, according 

to the present embodiment Reconstructing Pi may also be realized on 
any desired platform, all as required and appropriate. A sequence of 
operation, according to this embodiment includes: 
a) Generate Ii (222) from Pi (221); (see step b above in 200) 

10 b) Generate P' i (223) from Pj and Li; (see step e above in 200) 

c) Generate P'l (224) from Pi' and Di (210) by applying the 
modification commands of Z>z on P'l; 

d) Analyze &e so received Di difference result to determine the 
position and size of copied program fragments of P] and use L\ to 

15 create ALi (225 in Fig. 1 ), which translates the label enumeration 

. values appearing in P'l* back to their original address reference in 
the following manner: 
For a non-inserted referred address: 

^2[ii[matching address in P'l]] = address (first condition) 
20 For an inserted referred address: 

ALi{U( )] = address (second condition) 
Step (d) will now be exemplified with reference to the specific 
example of Fig. 2. Thus, in order to generate ALi (170), at first Li 
(130) is reconstructed, using to this end Lu P'l and Di all of which 
25 are available at the reconstruction side (220). Having reconstructed 

' ■ Li, ALi can be easDy derived by reversing. Li. More specifically, entry . 
1 in i2 holds the value 1 and accordingly, entry 1 of ALi holds the 
value 1/ Entry 5 of Li holds the value 5 and accordmgly, entry 2 in. 



CX 02339923 2001-02-02 

^0 00/11549 PCT/IL99/00446 

-26- 

ALi holds the value 5. By following the same reverse logic, entry 9 of 
Li holds the value 6 and accordingly entry 6 of ALi holds the value 9 
and lastly by following the same logic entry 3 of ALt holds the value 
11. 

e) Lastly, Pi (226) is reconstructed from P'l (224) and ALi 
(225) by translating address references in P'2 from label 
enumeration values back to the original address references using 
AL2. 

Step (e) will now be exemplified with reference to the specific 
example of Fig. 2. Thus, in order to reconstruct Pi (180), the label 
references ulFibk translated according to AL2. More specifically, 
label reference 2 m entry 2 of P'2 is replaced by actual ratiy reference 

5 in P2 according to the value 5 in entry 
# 2 of ALi. Likewise, label references 3 in entries 4 and 6 of are 
replaced by actual address reference 1 1 in P2, according to the value 1 1 
in entry # 3 of AL2. In a similar manner, label references 1 in entry 12 
of P^i is replaced by actual address reference 1 in 
P2 according to the value 1 in entry # 1 of AL2. Lastly, label reference 

6 in entry 7 of P\ is replaced by actual address reference 9 in P2, 
according to the value 9 m entry # 6 of ALi. As shown by this 

. particular example. Pi was generated indirectly fiom the difiference 
result data Z^, by the intermediary data structure, AL2n 

Entries 4 and 5 of ^2 hold the value 0, signifying that reference 
labels 4 and 5 need not be updated in Pi, since they form part of entries 
in Pi that were deleted 
- Those versed in the art will readily appreciate that whilst the invention has 
been described with reference to a specific application of updating software 
through a conmiunication network, the invention is by no means bound by tiiis 
specific application. Thus, by way of anotiier example, the invention is applicable 
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for efiBdent version control. Consider, for example, a series of program versions 
Pi Pi and Pj. Applying the technique of the invention gives rise to compact Dn 
and Dii^ which stand for the difference between Pi Pi and Pi Pj, respectively. 
The resulting compact D12 andiDjj ,as compared to conventional, larger in size, 

5 difference results, bring about the desired efficient version control tool. Other 
applications are, of course, feasible, all as required and appropriate. 

Having described the invention with reference to a specific application of. 
extraction differences between old and new versions of computer programs, there 
follows a deiscription with reference to a more generalized representation of data 

10 table depicted in the form of a graph. 

Before turning to the specific example, few observations which apply to 
the data table representation are set fordi below: 

. • The graph represents a collection of data-records inter-connected by 
references which enable to access them. 
IS • Data records are stored m a linear storage such as array according to a 
pre-defined order. 

• The amount of storage allocated for storing the references is not negligible. 

• The data that represents the references is not held as a contiguous block, 

but rather is dispersed among other items of the data table (e.g. among the 
20 data records). 

Bearing this in mind, attention is directed to Fig. 3A. The graph (300) 
represents an (old version of an) abstract data structure in the form of a graph 
(which is applicable in many applications as will be explained in greater details 
25 below). The nodes A-E represent data-records and the links represent references 
to other data-records. In this example, the pre-defined order for the data records 
is an alphabetical sort of records' names. The storage of the graph would appear 
as: 
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1. A, 2, 4 

2. B,3 

3. C.4,5 
5 4. D 

5. E,2 

Thus, for example, data-record A (301), having address 1, is linked by 
taeans of links (302 and 303) that stand for references 2 and 4 respectively, to 
data-records B ad D (304 and 305). As shown above, B and D reside in 
10 addresses 2 and 4 respectively; 

Should it now be required to modify the above graph by adding a 
data-record named ABA (306 in Fig. 3B) that is linked by means of link (307) to 
data-record D (305), this would bring about the following new gczph storage, 
where ABA is inserted in accordance with the said alphabetical order: 

15 1. A , 3, 5 

2. Aba, 5 

3. B, 4 

4. C.5,6 

5. D 

20 6- E, 3 

It is accordingly appreciated that insertion of only one data-record gave 
rise to fairly large differences between the storage of the old and the storage of 
the new graphs. 

25 It is readily appreciated that the above abstract data structure is similar to a 

computer program, except for the fact that in the specified data structure, 
alphabetical order, is imposed as compared to a computer program, where the 
order of execution is imposed. 
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Accordingty, applying the technique desmbed in detail with reference to 
Figs. 1 and 2 above would give rise to an extraction of compact differences. 

As specified above, the data table is by no means bound to the 
representation of a computer program. Thus, by way of non-limiting example, 

5 the specified graph (300) represents a map where nodes stand for cities and links 
for roads linking the various cities. The technique of the invention would allow 
for compact representation of topographical modification in the map (e.g. in 
response to the construction of a new road between the City having the symbol 
ABA and the city having the symbol D). 

10 By way of anoth^ non-limiting example^ the specified gn^h represents 

electronic circuitry where the nodes stand for the components and the links stand 
for the wiring coimections between the components. 

Numbers, alphabetic characters and roman symbols that ^ear in the 
following claims are designated for convenience of explanations only, and do not 

15 necessarily imply the particular order of the steps. 

The invention has been desoibed with a certain degree of particularity, but those 
versed in the art will readily appreciate that various alterations and modifications 
may be carried out without departing fiom the spirit and scope of the following 
Claims: 
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CLAIMS: 

1 . A method for generating a compact diflFerence result between an old 
program and a new program; each program includmg reference entries that 
contain reference that refer to other entries in the program; the method 
comprising the steps of: 

(a) scanning the old program and for substantially each reference entiy 
perfonn steps that include: 

0) replacing the reference of said entry by a distinct label marie, 
wherelof a modified old program is generated; 

(b) scamiing die new program and for substantially each reference entry 
perfonn steps that include: 

(i) replacing the reference of said entry by a distinct label mark, 
whereby a modified new program is generated; 

(c) generating said diflFerence result utilizkig directly or indirectly at 
least said modified old program and modified new program. 

2 . Tlie method of Claim 1 , fiirther comprising the step of: 

(d) transmitting said compact difference result over a commxmication 
network. 

3 . Hie method of Claim 2, wherein said network includes the Intmiet 

4 . The method of Claim 1 , further comprising the step of: 

(d) storing said compact diflference result on a storage medium. 

5 . A method for performing an update in an old program so as to generate a 
new program; each program including reference entries that contain reference 
that refer to other entries m the program; the method comprising the steps of: 

(a) receiving data that includes a compact difference result; said compact 
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difference result was generated utilizing a modified old program and a 
modified new program; 

(b) scanning the old program and for substantially each reference entry 
perform steps that include: 

© replacing the reference of said entry by a distinct label maik, 
whereby the modified old program is generated; 

(c) reconstituting the modified new program utilizing at least said 
compact differmce result and said modified old program; said 
modified new program is differed fiom said new program at least in 
diat substantial^ each reference entry in said new program is replaced 
in said modified new program by a distinct label mark; 

(d) reconstituting said new program utilizing directiy or indirect^ at least 
said compact difference result and said modified new program. 

6. The method of Claim 5, wherein said data is received in step (a) from a 
remote site through a network. 

7. The method of Claim 6, wherein said network mcludes the Internet 

8- A method for generating a compact difference result between an old 
program and a new program; each program including reference entries that 
contdn reference that refer to other entries in the program; the method 
comprising the steps of: 

(a) generating a modified old program utilizing at least said old program; 

(b) generating a modified new program utilizing at least said new 
program, said modified old program and modified new program have 
at least the following characteristics: 

(i) substantially each reference in an entry in said old program that 
is different than corresponding entry in said new program due to 
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delete/insert modifications that ifonn part of the transitioii 
between said old program and new program are reflected as 
invariant references in the corresponding entries in said modified 
old and modified new programs; 
5 (c) generating said compact difference result utilizing at least said 
modified new program and modified old program. 

9 . The method of Claim 8, further comprising the step of: 

(d) transmitting said compact difference result over a communication 
10 network. 

10 • The method of Claim 9, wherein said network includes the Internet 

11. The method of Claim 8, further comprising flxe step of: 

IS (d) storing said compact difference result on a storage medium. 

12 . A method for perfomMng an update in an old program so as to generate a 
new program; each program including reference entries that contain reference 
that refer to other entries in the program;, the method conq>rising the steps of: 

' (a). . receiving data that includes a compact difference result; said compact 
difference result was generated utiliziiig a modified old program and a 
modified new program; 
(b) generating a modified old program utilizing at least said old program; 
25 (c) reconstituting a modified new program utilizing directly or iadirectly 
at least said modified old program and said compact difference result; 
said modified old program and modified new program have at least the 
following characteristics: 

(i) substantially each reference in an entry in said old program that 
30 is different than corresponding entry in said new program due to 
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delete/inset modifications that foim part of the transition 
between said old program and new program are reflected as 
invariant refermces in the corresponding entries in said modified 
old and modified new programs; 
(d) reconstituting said new program utilizing directly or indirectly at least 
said compact difference result and said modified new program. 

13 . The method of Claim 5, wherein said data is received in step (a) fix)m a 
storage medium. 



14. A system for generating a compact difference residt between an old 
program and a new program; each program including reference entries that 
cont^ reference that refer to other entries in the program; die system comprising 
a processing device capable of: 
15 (a) scaiming the old program and for substantially each reference, entiy 
perform steps that include: 

(i) replacing the reference of said entry by a distinct label mark, 
whereby a modified old program is generated; 

(b) scanning the new program and for substantially each reference entry 
20 perform steps that include: 

(i) replacing the reference of said entry by a distinct label mark, 
whereby a modified new program is generated; 

(c) generating said difference result utilizing directly or indirectly at 
least said modified old program and modified new program. 



15 • ; The system of Claim 14, wherein said processor device is further capable 
of transmitting said compact difference result over a communication network. 



16 . The system of Claim 15, wherein said network mcludes the Internet. 
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17 . The system of Claim 14, wherein said processor device is further capable 
of storing said compact difference result on a storage medium. 

18. A system for performing an update in an old program so as to generate a 

5 new program; each program including referaice entries that contain reference 

that refer to other entries in the program; the system comprising a processing 
device capable of : 

(a) . receiving data that includes a compact difference result; said compact 
10 difference result was generated utilizing a modified old program and a 

modified new program; 
G>) scanning the old program and for substantially each reference entry 
perform steps diat include: 

0) replacing the reference of said entry by a distinct label maflf^ 
15 . whereby the modified old program is generated; 

(c) reconstituting the modified new program utili2dng at least said 
compact difference result and said modified old program; said 
modified new program is differed from said new program at least in 
that substantially each reference entry in said new program is replaced 

20 in said modified new program by a distinct label mark; 

(d) reconstituting said new program utilizing directly or indirectly at least 
said compact difference result and said modified new program, 

19 . The system of Claim 18, wherein said data is received from a remote site 
25 through a network. 

20 . The system of Claim 19, wherein said network includes the Internet. 

21. A system for generating a compact difference result between an old 
program and a new program; each program including reference entries that 

30 contain reference that refer to other entries in the program; the system comprising 
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a processing device capable of : 

(a) geaerating a modified old program utilizing at least said old program; 

(b) generating a modified new program ufilizing at least said new 
program, said modified old program and modified new program have 

5 at least the following characteristics: 

(i) substantially each reference in an entry in said old program that 
is different than corresponding entry in said new program due to 
delete/insert modifications that form part of the transition 
between said old program and new program are reflected as 
10 invariant references in the corresponding entries in said modified 

old and modified new programs; 

(c) generating said compact difference result utilizing at least said 
modified new program and modified old program. 

15 22. The system of Claim 21, wherein said processor i^ finther capable of 
transmitting said compact difference result over a cornmunication network. 

23 . The system of Claim 22, wherein said network includes the Internet 

20 24 . The system of Claim 21, wherein said processor is fiirther capable of . 
storing said compact difference result on a storage medium. 

25 . A system for performing an update in an old program so as to generate a 
new program; each program including reference entries that contain reference 
25 that refer to other entries in the program; the system comprising a processing 
device capable of : 
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(a) receivmg data that includes a compact diflference result; said compact 
difference result was generated utilizing a modified old program and a 
modified new program; 
5 . (b) generating a modified old program utilizing at least said old program; 

(c) reconstituting a modified new program utilizing directiy or indirectiy 
at least said modified old program and said compact diflference result; 
said modified old program and modified new program have at least the 
following characteristics: 

10 (i) substantially each reference in an entry in said old program that 

is difierent than corresponding entry in said new program due to 
delete/inset modifications that form part of the transition 
between said old program and new program are reflected as 
invariant references in the corresponding entries in said modified 

15 old and modified new programs; 

(d) reconstituting said new program utilizing directiy or indirectly at least 
said compact difference result and said modified new program. 

26 . The system of Claim 18, wherein said data is received in step (a) firom a 
20 storage medium. 

27 . A processing device having associated therewith a storage medium which 
holds compact diflference result data that was generated by the method of anyone 
of Claims 1 to 4. 



25 



28 . A processing device having associated therewith a storage medium which 
holds_ compact difference result data that was generated by the method of anyone 
ofClaimsStolL 
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29 . The method of Claim 12, wherein said data is received ia sttp (a) from a 
remote site through a network. 

30 . The method of Claim 29, wherein said network includes the Intemet 

5 31 . The method of Claim 12, wherein said data is received in stq> (a) from a 
storage medium. 

32 • The system of Claim 25, wherein said data is received in step (a) from a 
remote site through a netwoik. 

33 . The system of Claim 32, wherein said network includes the Internet 
10 34 . The system of Claim 25, wherein, said data is received ia step (a) from a 
storage medium. 

35. A method for generating a compact difference result between an old data 
table and a new data table; each data table including refermce entries that contain 
reference that refer to other entries in tfie data table; the method comprising the 

15 stqjs of: 

(a) scanning the old data table and for substantially each reference entry 
perform stqps that ioclude: . 

(Q replacing the reference of said entiy by a distinct label mark, 
whereby a modified old data table is generated; 
20 Qy) scanning the new data table and for substantially each reference entry 
perform steps that include: 

Q) replacing tiie reference of said entiy by a distinct label marie, 
whereby a modified new data table is generated; 

(c) generating said difference result utilizing directly or indirectly at 
25 least said modified old data table and modified new data table. 

36 . The method of Claim 35, fiirther comprising the step of: 

(d) transmitting said compact, difference result over a communication 
network. 
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37 . The method of Claim 36, wherein said network includes the Intonet 

38, The method ofClaim 35, further comprising the step of: 

. (d) storing said compact difference result on a storage medium, 

5 

3 9 . A method for perfonning an update in an old data table so as to generate a 
new data table; each data table including reference entries that contain reference 
that refer to other entries in the data table; the method comprising the stqjs of: 

10 (a) receiving data that mcludes a compact diflference result; said compact 
difference result was generated utilizmg a modijSed old data table and 
a modified new data table; 

(b) scamiing the old data table and for substantial^ each reference ento^ 
perfomi steps that include: 

15 (i) replacing the reference of said entiy by a distinct label mark, 

whereby the modified old data table is generated; 

(c) reconstituting the modified new data table utilizing at least said 
compact difference result and said modified old data table; said 
modified new data table is dififCTed from said new data table at least in 

20 that substantially each reference entry in said new data table is 

replaced in said modified new data table by a distinct label mark; 

(d) reconstituting said new data table utilizing directly or mdirectly at 
least said compact difference result and said modified new data table. 

25 40 . The method of Claim 39, wherein said data is received in step (a) from a 
remote site through a network. 

41 . The method of Claim 40, wherein said network includes the Internet 
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42 . A method for generating a compact difference result between an old data 
table and a new data table; each data table including reference entries that contain 
reference that refer to other entries in the data table; the method comprising the 
5 Steps of: 

(a) generating a modified old data table utilizmg at least said old data 
table; 

(b) generating a modified new data table utilizing at least said new data 
table, said modified old data table and modified new data table have at 

. 10 least the following characteristics: 

(i) substantially each reference m an entry in said old data table 
that is different than corresponding entry m.said new data table 
due to deleteTinsert modifications tiiat form part of the transition 
between said old data table and new data table are reflected as 
15 invariant references m the corresponding entries in said modified 

old and modified new data tables; 

(c) generating said coinpact difference result utilizing at least said 
modified new data table and modified old data table. 

20 43 • The method of Claim 42, fijrther comprising the step of: 

(d) transmitting said coinpact difference result over a communication 
network. 

The method of Claim 43, wherein said network includes the Internet 

.The method of Claim 42, further comprising the step of: 
(d) storing said compact difference result on a storage medium. 
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46 . A method for perfonning an update in an old data table so as to generate a 
new data table; each data table including reference entries that contain reference 
that refer to other entries in the data table; the method comprising the steps of: 

5 

(a) receiving data that includes a compact difference result; said compact 
difference resuh was generated utilizing a modified old data table and 
a modified new data table; 
, (b) generating a modified old data table utilizing at least said old data 
10 table; 

(c) reconstituting a modfied new data table utilizing directly or indirectly 
at least said modified old data table and said compact difference result; 
said modified old data table and modified new data table have at least 
the following characteristics: 

15 ' (0 substantially each reference in an entry in said old data table 

that is different than corresponding entry in said new data table 
due to delete/inset modifications that form part of the transition 
between said old data table and new data table are reflected as 
invariant references in the corresponding entries in said modified 

20 old and modified new data tables; 

(d) reconstituting said new data table utilizing directly or indirectly at 
least said compact difference result and said modified new data table. 



47 . The method of Claim 39, wherein said data is received in stq) (a) from a 
25 storage medium. 
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48 . A system for generatmg a compact difference resdt betw^ data 
table and a new data table; each data table including reference entries that contain 
reference that refer to other entries in the data table; the system comprising a 

5 processing device capable of: 

(a) scanning the old data table and for substantially each reference entry 
perform steps that include: 

(i) replacing the reference of said entry by a distinct label mark, 
. whereby a modified old data table is generated; 
10 (b) scaiming the new data table and for substantially each reference entry 
perform steps that include: 

(i) rq)lacing the reference of said entry by a distinct label mark, 
whereby a modified new data table is generated; 
(c) generating said difference result utilizing directly or indirectly at 
15 least said modified old data table and modified new data table. 

49 • The system of Claim 48, wherein said processor device is further capable 
of trans m it t i n g said compact difference result over a communication network, 

20 SO - The system of Clam 49, wherein said network includes the Internet 

51. The system of Claim 48, wherein said processor device is fiirther capable 
of storing said compact difference result on a storage medium. 

25 52 • A system for performing an update in an old data table so as to generate a 
new data table; each data table including reference entries that contain reference 
that refer to other entries in the data table; the system comprising a processing 
device capable of : 

(a) receiving data that includes a compact difference result; said compact 
30 difference resuh was generated utilizing a modified old data table and 
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a modified new data table; 

(b) scanning the old data table and for substantially each reference entry 
perfonn steps that include: 

(i) replacing the reference of said entry by a distinct label mark, 
whereby the modified old data table is generated; 

(c) reconstituting the modified new data table utilizing at least said 
compact difference result and said modified old data table; said 

modified new data table is differed firom said new data table at least in 
that substantially each reference entry in said new f^^t^ table is 
rq)laced in said modified new data table by a distinct label mark; 

(d) reconstituting said new data table utilizing directly or indirectly at 
least said compact difference result and said modified new data table. 

53 . The system of Claim 52, wherein said data is received firom a remote site 
through a network. . . 

54 . The system of Claim 53, wherein said network includes the Internet 

55 . A system for generating a compact difference result between an old data 
table and a new data table; each data table including reference entries that contam 
reference that refer to other entries in the data table; the system , comprising a 
processing device capable of : 

(a) generating a modified old data table utilizing at least said old data 
table; 

(b) generating a modified new data .table utilizing at least said new data 
table, Sdld modified old data table and modified new data table have at 
least the following characteristics: 

(i) substantially each reference in an entry in said old data table 
that is different than corresponding entry in said new data table 
due to deleteAnsert modificiations that form part of the transition 
between said old data table and new data table are reflected as 
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invariant references in the coiresponding entries in said modified 
old and modified new dat^ tables; 
(c) genenrtmg said compact difiference resuit utilizing at least said 
modified new data table and modified old data table. 

56. The system of Claim 55, wherein said processor is further, capable of 
transmitting said compact difference result over a communication network. 

57 . Tlie system of Claim 56, wherein said netwoA includes the IntemeL 

58 . The system of Claim 55. wherein said processOT is fiirther enable of 
storing said compact difference result on a storage medium. 

59 . A system for performing an update in an old data table so as to generate a 
new data table; each data table including reference entries that contain reference 
that refer to other entries in the data table; the system comprising a processing 
device capable of : 

(a) receiving data that includes a compact difference result; said compact 
difference result was generated utilizing a modified old data table and 
a modified new data table; 

(b) generating a modified old data table utilizing at least said old data 
table; 

(c) reconstituting a modified new data table utilizing directly or mdirectly 
at least said modified old data table and said compact difference result; 
said modified old data table and modified new data table have at least 
the following characteristics: 

(0 substantially each reference in an entry in said old data table 
that is different than corresponding entry in said new data table 
due to delete/inset modifications that fonn part of the transition 
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between said old data "table and new data table are reflected as 

invariant references in the corresponding entries m said modified 
old and modified new data tables; 

(d) reconstituting said new data table utilizing directly or indirectly at 

5 J^ast said compact difference result and said modified new data table 

60 . The system of Claim 59, wherein said data is received hi step (a) firam a 
storage medium. 

10 61. A processing device having associated therewith a storage medium which 
holds compact difference result data that was generated by the method of anyone 
ofaaims35to38. 

62 . A processmg device haymg associated therewith a storage medium which 
15 holds compact difference result data that was generated by the method of anyone 

ofClaims42to45. 

63 . The method of Claim 46, wherem said data is received in step (a) from a 
remote site through a networic 

20 

64 . The method of Claun 63, wherdn said networic includes the Internet 

65 . The method of Claim 46, wherein said data is received in step (a) from a 
storage medium. 

66 . The system of Claun 59. wherem said data is received in step (a) from a 
25 remote site through a network. 

67 . The system of Claim 66, wherein said network includes the Internet. 

68 . The system of Claim 59, wherein said data is received in step (a) from a 
. storage medium. 
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